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LISTING OF THE CLAIMS 

1. (Currently amended) A method of editing an initial image, comprising the steps 
of: 

- [[A]]a first process requesting a filter from a second process; 

- [[S]]said first process defining a relationship between said filter and said 
initial image, said related filter and initial image comprising a program, 

- [[S]]said second process compiling said program, yielding a compiled 
program; 

- [[Rerunning at least a portion of said compiled program to apply a function 
of said filter to said image, yielding an pixel-image result. 

2. (Currently amended) The method of claim 1 having the additional step of 

- [[0]]optimizing said program. 

3. (Original) The method of claim 2, wherein the step of optimizing includes the 
step of using a cache look-up to see if said pixel-image result is already in cache. 

4. (Original) The method of claim 2, wherein the step of optimizing includes the 
step of calculating an intersection, said intersection representing an area where 
said pixel-image result is both defined and in a result region requested of said 
second process. 

5. (Previously Presented) The method of claim 4 further comprising the step of 
using said calculated intersection to limit the number of pixels that require 
calculation during said running of said compiled program. 

6. (Original) The method of claim 4 further comprising the step of, using said 
calculated intersection to limit the amount of memory necessary for storing 
calculated images. 
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7. (Original) The method of claim 1 wherein said compiled program is for a single 
microprocessor. 

8. (Original) The method of claim 1 wherein said compiled program comprises a 
component for a first microprocessor and a component for a second 
microprocessor. 

9. (Original) The method of claim 7 wherein said single microprocessor is a CPU. 

10. (Original) The method of claim 7 wherein said single microprocessor is a 
programmable GPU. 

11. (Original) The method of claim 8 wherein said first microprocessor is a CPU and 
said second microprocessor is a GPU. 

12. (Original) The method of claim 8 wherein said first and second microprocessors 
are both CPUs. 

13. (Original) The method of claim 8 wherein said first and second microprocessors 
are both GPUs. 

14. (Original) The method of claim 1 wherein said initial image is only a color. 

15. (Original) The method of claim 1 wherein said first process is an application 
program. 

16. (Original) The method of claim 1 wherein said second process comprises a suite 
of graphics services functions. 

17. (Original) The method of claim 1 wherein an operating system comprises said 
second process. 
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18. (Original) The method of claim 1 wherein said first process requests a high-level 
filter and said second process responds with an object representing a lower-level 
filter. 

19. (Original) The method of claim 1 wherein said first process and second process 
run on a CPU and said compiled program runs on a GPU. 

20. (Original) The method of claim 2 wherein said first process and second process 
run on a CPU and said compiled program runs on a GPU. 

21. (Original) The method of claim 5 wherein said first process and second process 
run on a CPU and said compiled program runs on a GPU. 

22. (Currently amended) A system for editing an initial image, comprising: 

- [[A]]a first microprocessor running a first process and a second process for 
servicing requests from said first process; 

- [[A]]a memory for storing a filter, said filter requested by said first process; 

- [[A]]a second memory for storing a data structure comprising a relationship 
between said initial image and said filter, said first process causing the 
creation of said data structure; 

- [[A]]a second microprocessor for running a program created using said data 
structure; 

- [[A]]3 third memory for storing a pixel image resulting from running said 
program. 

23. (Original) The system of claim 22 wherein said first and second memories are 
the same. 

24. (Previously Presented) The system of claim 22 wherein said first, second and 
third memories are the same. 
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25. (Original) The system of claim 22 wherein said first and second memories are in 
system memory and said third memory is in video memory. 

26. (Original) The system of claim 22 wherein said first microprocessor processes 
said data structure to produce said program for use on said second 
microprocessor. 

27. (Original) The system of claim 22 wherein said second microprocessor, under 
control of said program, causes said pixel image to be stored in said third 
memory. 

28. (Previously Presented) A method of creating a result image comprising the steps 
of: 

- a first process requesting the creation of a context; 

- said first process requesting the creation of a result image; 

- said first process indicating parameters associated with the creation of said 
result image; 

- said first process requesting that said result image be rendered to said 
context; 

- a second process servicing said requests of said first process, said servicing 
comprising the steps of: 

■ optimizing a graph representing said result image; 

■ compiling said optimized graph; 

■ causing the rendering of said compiled optimized graph into said 
context. 

29. (Original) The method of claim 28 wherein said creation of said result image 
comprises editing a pre-existing image. 
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30. (Currently amended) The method of claim 28 wherein said step of optimizing a 
graph representing said first image comprises the step of: 

- [[C]]calculating an intersection, said intersection representing an area where 
said result image is both defined and requested as a result by said first 
process. 

31. (Currently amended) The method of claim 28 wherein said step of optimizing a 
graph representing said first image comprises the step of: 

- [[A]]analyzing adjacent nodes in said graph for the purpose of attempting to 
consolidate nodes. 

32. (Currently amended) The method of claim 30 wherein said step of optimizing a 
graph representing said first image comprises the additional step of: 

- [[A]]analyzing adjacent nodes in said graph for the purpose of attempting to 
consolidate nodes. 

33. (Original) The method of claim 31 wherein the step of analyzing adjacent nodes 
comprises the step of checking a cache to determine if the result of such analysis 
is available in a memory. 

34. (Original) The method of claim 28 wherein the step of optimizing said graph 
comprises the step of checking a cache to determine if said graph has already 
been optimized. 

35. (Original) The method of claim 28 wherein the step of optimizing said graph 
comprises the step of checking a cache to determine if the result of rendering 
said graph is available in a memory. 

36. (Original) The method of claim 28 wherein said first process requests the output 
of a graph programmatically assembled by said first process and comprising one 
or more pre-defined filters. 
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37. (Original) The method of claim 36 wherein said first process programmatically 
assembled said graph in cooperation with said second process. 

38. (Original) The method of claim 28 wherein said first process is an application 
program. 

39. (Original) The method of claim 28 wherein said second process comprises a suite 
of graphics services functions. 

40. (Original) The method of claim 39 wherein an operating system comprises said 
second process. 

41. (Original) The method of claim 28 wherein an operating system comprises said 
second process. 

42. (Original) The method of claim 28 wherein said second process inserts nodes 
into said graph for converting an original color scheme to an operating color 
scheme and for converting the operating color scheme back to the original color 
scheme. 
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43. (Original) A method of creating an result image comprising the steps of: 

- a first process running on a first microprocessor requesting the creation of a 
context; 

- said first process requesting the creation of a result image; 

- said first process indicating parameters associated with the creation of said 
result image; 

- said first process requesting that said result image be rendered to said 
context; 

- a second process running on said first microprocessor servicing said requests 
of said first process, said servicing comprising the steps of: 

■ optimizing a graph representing said result image; 

■ compiling said optimized graph; 

■ causing rendering of said compiled optimized graph into said context, 
said rendering occurring on a second microprocessor. 

44. (Original) The method of claim 43 wherein said creation of said result image 
comprises editing a pre-existing image. 

45. (Currently amended) The method of claim 43 wherein said step of optimizing a 
graph representing said first image comprises the step of: 

- [[C]]calculating an intersection, said intersection representing an area where 
said result image result is both defined and requested by said first process. 

46. (Currently amended) The method of claim 43 wherein said step of optimizing a 
graph representing said first image comprises the step of: 

- [[A]]analyzing adjacent nodes in said graph for the purpose of attempting to 
consolidate nodes. 
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47. (Currently amended) The method of claim 45 wherein said step of optimizing a 
graph representing said first image comprises the additional step of: 

- [[A]]analyzing adjacent nodes in said graph for the purpose of attempting to 
consolidate nodes. 

48. (Original) The method of claim 46 wherein the step of analyzing adjacent nodes 
comprises the step of 

- checking a cache to determine if the result of such analysis is available in a 
memory. 

49. (Original) The method of claim 43 wherein the step of optimizing said graph 
comprises the step of 

- checking a cache to determine if said graph has already been optimized. 

50. (Original) The method of claim 43 wherein the step of optimizing said graph 
comprises the step of 

- checking a cache to determine if the result of rendering said graph is 
available in a memory. 

51. (Original) The method of claim 43 wherein said first process requests the output 
of a graph programmatically assembled by said first process and comprising one 
or more pre-defined filters. 

52. (Original) The method of claim 51 wherein said first process programmatically 
assembled said graph in cooperation with said second process. 

53. (Original) The method of claim 43 wherein said first process is an application 
program. 

54. (Original) The method of claim 43 wherein said second process comprises a suite 
of graphics services functions. 
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55. (Original) The method of claim 54 wherein an operating system comprises said 
second process. 

56. (Original) The method of claim 43 wherein an operating system comprises said 
second process. 

57. (Original) The method of claim 43 wherein said second process inserts nodes 
into said graph for converting an original color scheme to an operating color 
scheme and for converting the operating color scheme back to the original color 
scheme. 

58. (Currently amended) A method for providing a high level interface to a graphics 
processing resource comprising: 

- [[A]]a first process requesting performance of a task through one or more 
function calls serviced by said graphics processing resource, said function 
calls selected from one or more of the following options, (i) creating of an 
image, (ii) creating a filter, (iii) setting arguments associated with said filter, 
(iv) asking for the output of said filter or another filter, (v) creating a context; 
and (vi) rendering an image to said context or another context; 

- [[S]]said request having an object associated therewith, said object 
comprising one of the following: a context, an image, a filter, or a vector; 

- [[S]]said request defining a relationship between at least one of said 
functions and one of said objects, 

- [[S]]said graphics processing resource servicing said request. 

59. (Original) The method of claim 58 wherein said request is serviced using a GPU 
and a CPU. 

60. (Original) The method of claim 58 wherein said request is serviced using an 
emulator to run a GPU program on a CPU. 
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61. (Original) The method of claim 58 comprising the additional step of creating a 
graph representing an image. 

62. (Original) The method of claim 61 comprising the additional step of optimizing 
said graph. 

63. (Currently amended) A method for providing a high level interface to a graphics 
processing resource comprising: 

- [[A]]a first process requesting performance of a task through one or more 
function calls serviced by said graphics processing resource, said function 
calls selected from one or more of the following options, (i) creating of an 
image, (ii) creating a context; and (v) rendering an image to said context or 
another context; 

- [[S]]said request having an object associated therewith, said object 
comprising one of the following: a context, or an image 

- [[S]]said request defining a relationship between at least one of said 
functions and one of said objects, 

- [[S]]said graphics processing resource servicing said request. 

64. (Original) The method of claim 63 wherein said request is serviced using a GPU 
and a CPU. 

65. (Original) The method of claim 63 wherein said request is serviced using an 
emulator to run a GPU program on a CPU. 

66. (Original) The method of claim 63 comprising the additional step of creating a 
graph representing an image. 

67. (Original) The method of claim 66 further comprising the step of optimizing said 
graph. 
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68. (Original) The method of claim 63, wherein said function calls include the option 
of creating a filter. 

69. (Original) The method of claim 63 wherein said function calls include the option 
of setting arguments associated with said filter. 

70. (Original) The method of claim 68 wherein said function calls include the option 
of setting arguments associated with said filter 

71. (Previously Presented) The method of claim 63 wherein said another object 
associated with said request may comprise a filter. 

72. (Original) The method of claim 63 wherein another object associated with said 
request may be a vector. 

73. (Original) The method of claim 71 wherein another object associated with said 
request may be a vector. 

74. (Currently amended) A method for rendering an image comprising the steps of: 

- [[A]]a first process running on a CPU requesting the creation of an image; 

- [[A]]a graphics services resource, responding to said request by running a 
first routine on said CPU, said first routine for optimizing a graph representing 
said image; 

- [[S]]said first process requesting the rendering of said image to a specified 
context; 

- [[S]]said graphics services resource causing the rendering of said graph 
representing said image, said rendering occurring on a GPU. 
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75. (Currently amended) A method for converting a first image representation into a 
second image representation, comprising the steps of: 

- [[C]]creating a first graph associated with said first image representation 
where software routines for creating such graph execute on a CPU, 

- [[D]]determining an intersection of the first graph's global domain of 
definition and global region of interest; 

- [[R]]resolving a first node in said first graph by running software routines on 
said CPU to (i) determine if said first node may be combined with a second 
node and (ii) create program steps for calculating and storing only the 
portions of any intermediary image that relate to said intersection, said 
program steps for compilation on said CPU and execution on a GPU. 

76. (Original) The method of claim 75 wherein the step of determining if said first 
node may be combined with said second node comprises the step of checking a 
cache to determine if there is a result in memory regarding such determination 
regarding combining nodes. 

77. (Original) The method of claim 75 wherein the step of resolving said first node 
comprises the step of checking a cache to determine if there is a result in 
memory regarding the resolution of said first node. 

78. (Original) The method of claim 75 wherein said first node is a root node. 

79. (Original) An image processing application program interface embodied on one 
or more computer readable media, comprising: a first group of services related 
to filter objects; a second group of services related to image objects; a third 
group of services related to context objects; and a fourth group of services 
related to vector objects. 
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80. (Original) The image processing application program interface of claim 79, 
wherein the first group of services comprise: first functions to create filter 
objects; second functions to set filter object parameters; and third functions to 
obtain filter object output. 

81. (Original) The image processing application program interface of claim 79 
wherein the second group of services comprise: first functions to create image 
objects; and second functions to render an image object to a context object. 

82. (Original) The image processing application program interface of claim 79, 
wherein the third group of services comprise first functions to create context 
objects. 

83. (Original) The image processing application program interface of claim 79 
wherein the fourth group of services comprise: first functions to create vector 
objects. 

84. (Original) An application program interface for facilitating image processing, the 
application program interface comprising functions to: create image objects; 
create context objects; create filter objects; set filter object parameters; obtain 
filter object output; and convert image objects into context objects. 

85. (Original) A computer-readable medium having computer executable instructions 
for performing the method recited in any one of claims 1, 28, 43, 58, 63, 74 
or 75. 



14 of 32 



